# MODIFIED NODAL ANALYSIS STAMPS

#### B.1 MODIFIED NODAL ANALYSIS MATRIX STAMPS

The purpose of this appendix is to give a summary of modified nodal analysis (MNA) stamps [1]. They show how to enter circuit elements into the MNA matrix. In this book, we concentrated on linear elements. For most circuit solvers, the linear part is an important subset of a program. Further, details and references on this subject can be found in Refs [1–5]. In general, we attempt to adhere to the basic SPICE language statements [6] as a command language for the overall solution approach. The fundamental MNA concepts are presented in Chapter 2. For the convenience of the reader, we duplicate the circuit element Table B.1. The stamps represent contribution of the circuit elements in the table to the MNA matrix.

To repeat the key issue, the element-by-element stamping concept is based on the incomplete Kirchhoff's circuit law in Section 2.3.4. Hence, for each node, we stamp a circuit element contribution at the time into the matrix. The Kirchhoff's current law (KCL) is satisfied at each node, as soon as all the elements that belong to the node are stamped into the circuit matrix. The stamps not only add the elements to the MNA matrix, but they also add the entries needed in to the connection matrices  $\bf A$  and  $\bf A^T$ . In general, if one of the nodes is connected to ground or reference node, then the contribution of this part in the stamp is eliminated. This usually results in the elimination of a row and a column in the element stamp.

## **B.1.1** Resistor

Two different stamps can be used for the resistor shown in Fig. B.1 depending on whether we would like to have the current as an output variable or not. An example of the SPICE statement for the resistor is

RName Node1Name Node2Name 5kOhms

|                                          |                    | •                 |
|------------------------------------------|--------------------|-------------------|
| Circuit elements                         | Frequency domain   | Time domain       |
| R Resistance                             | V(s) = R I(s)      | $v(t) = R \ i(t)$ |
| C Capacitance                            | $I(s) = s \ CV(s)$ | i(t) = C dv(t)/dt |
| L Inductance                             | V(s) = sLI(s)      | v(t) = L di(t)/dt |
| Current controlled voltage source (CCVS) | V(s) = h I(s)      | v(t) = h i(t)     |
| Current controlled current source (CCCS) | I(s) = f I(s)      | v(t) = f i(t)     |
| Voltage controlled voltage source (VCVS) | V(s) = e V(s)      | $v(t) = e \ v(t)$ |
| Voltage controlled current source (VCCS) | I(s) = g V(s)      | i(t) = g v(t)     |

TABLE B.1 Small list of circuit elements for which we need MNA matrix stamps.



**FIGURE B.1** Resistor connected to two nodes in circuit.

TABLE B.2 Matrix element stamp for resistor  $R_{k\ell}=1/G_{k\ell}$  for  $R_{k\ell}\neq 0$ .

| Row/column     | $V_k$        | $V_{\ell}$   | RHS |
|----------------|--------------|--------------|-----|
| $\overline{k}$ | $G_{k\ell}$  | $-G_{k\ell}$ | 0   |
| $\ell$         | $-G_{k\ell}$ | $G_{k\ell}$  | 0   |

where the first character of the name needs to be R and  $Node1Name = V_k$  and  $Node2Name = V_\ell$  as an example for the notation used below. In our example, the resistance value is  $5 \, \mathrm{k}\Omega$ . The first stamp is used if the current through the resistor is not needed as an unknown output. Also, we assume that the value of the resistor is never set to zero since the form of the equation is  $I = G_{k\ell}(V_k - V_\ell)$  where  $G_{k\ell} = 1/R_{k\ell}$ . The resistor stamp is given in Table B.2.

The stamp where the current is specified as an unknown is given in Table B.3.

TABLE B.3 Matrix element stamp for resistor  $R_{k\ell}$  with current.

| Row/Column     | $V_k$ | $V_{\ell}$ | I            | RHS |
|----------------|-------|------------|--------------|-----|
| $\overline{k}$ |       |            | +1           | 0   |
| $\ell$         |       |            | -1           | 0   |
| Aux            | 1     | -1         | $-R_{k\ell}$ |     |



FIGURE B.2 Capacitance connected between two nodes.

TABLE B.4 Matrix stamp for capacitor in the frequency domain.

| Row/Column     | $V_{k}$     | $V_l$       | RHS |
|----------------|-------------|-------------|-----|
| $\overline{k}$ | $s C_{kl}$  | $-s C_{kl}$ | 0   |
| l              | $-s C_{kl}$ | $s C_{kl}$  | 0   |

TABLE B.5 Matrix stamp for capacitor in the time domain.

| Row/Column | $V_k$         | $V_l$         | RHS                                                                               |
|------------|---------------|---------------|-----------------------------------------------------------------------------------|
| k          | $k_p C_{kl}$  | $-k_p C_{kl}$ | $C_{kl} k_{p-1} (-V_k^{p-1} + V_l^{p-1})$                                         |
| l          | $-k_p C_{kl}$ | $k_p C_{kl}$  | $C_{kl} k_{p-1} (-V_k^{p-1} + V_l^{p-1}) C_{kl} k_{p-1} (-V_l^{p-1} + V_k^{p-1})$ |

Note that in the stamp that includes the unknown current in Table B.3, we use  $R_{k\ell}$  rather than  $G_{k\ell}$ . Then, the entry does not lead to a singular circuit matrix for the case if  $R_{k\ell}=0$ . The additional equation added to the stamp is called Aux.

### **B.1.2** Capacitor

Next, we consider a capacitor for which we need element stamps for the time as well as the frequency domain. An example for the use of a capacitance stamp is given in Section 2.7. The capacitor circuit element connected between two nodes k and l is shown in Fig. B.2. The frequency domain element stamp is closely related to the resistance stamp (Table B.4). To obtain the capacitance stamp we can replace the conductance G = 1/R with the admittance Y = sC, which leads to the matrix stamp for capacitor as shown in Table B.4.

The details for the time domain formulation are given in Section 2.4. The time domain element stamp for a capacitor is shown in Table B.5.

### **B.1.3** Independent Voltage Source

Independent voltage sources are very often used as input sources in circuits. The general case for such a source is shown in Fig. B.3.

An interesting aspect is that the basic stamp is the same for the frequency and the time domains. Only the values of the source itself represent if it is a time or frequency domain source or both. We notice that the stamp automatically has the current of the source as an unknown (Table B.6).

## **B.1.4** Independent Voltage Source with Series Elements

In many cases, voltage sources also include a series resistance or an impedance that represents a typical source. For this case, the element stamp for the source is augmented with an impedance Z(s) that can consist of several elements in the frequency domain. Hence, examples for Z are simple R or an R-L series connection circuit models. Of course, some elements can also be included in the time domain. The interesting aspect is the fact that a single stamp can be used for the combination. The equivalent circuit is given in Fig. B.4.

The stamp for this is given in the frequency domain, which is similar to the zero impedance source (Table B.7).



FIGURE B.3 Independent voltage source connected between two nodes.

TABLE B.6 Matrix element stamp for voltage source.

| Row/column     | $V_k$ | $V_l$ | I  | RHS      |
|----------------|-------|-------|----|----------|
| $\overline{k}$ |       |       | 1  |          |
| l              |       |       | -1 |          |
| Aux            | 1     | -1    | 0  | $V_{kl}$ |



**FIGURE B.4** Voltage source connected between one or two nodes.

| Row/Column     | $V_k$ | $V_l$ | I     | RHS      |
|----------------|-------|-------|-------|----------|
| $\overline{k}$ |       |       | 1     | 0        |
| l              |       |       | -1    | 0        |
| Aux            | 1     | -1    | -Z(s) | $V_{kl}$ |

TABLE B.7 Matrix element stamp for voltage source.



**FIGURE B.5** Independent current source connected to two nodes.

TABLE B.8 Matrix stamp for current source.

| Row/column | $V_k$ | $V_{\ell}$ | RHS          |
|------------|-------|------------|--------------|
| k          |       |            | $-I_{k\ell}$ |
| $\ell$     |       |            | $I_{k\ell}$  |

#### **B.1.5** Independent Current Source

Independent current sources also frequently serve as input sources as shown in Fig. B.5. A short circuit is also used as an element that does not alter the circuit's performance, but it is also frequently used as a way to obtain the output of an additional current that does not appear in the conventional output vector.

The entry into the right-hand side for the matrix system is given for the case when both nodes of the source are part of the circuit. One of the two entries is eliminated for the case when one node of the source is connected to ground. We note that this stamp is entered into the RHS. As we can see, there are no entries into the MNA matrix for a current source (Table B.8).

#### **B.1.6** Short Circuit Connection

For some applications, short circuits are required. An interesting application is the connection of different subparts from different model parts. Figure B.6 shows the equivalent circuit for the short if we set the source voltage to zero. This shows that the voltage source model (Table B.3) can also be used for a short (Table B.9).

As we can see, the stamp for a short also introduces the current through the short. Hence, it also can be used to determine the current through a wire without introducing a series impedance. Hence, it will not change the circuit behavior.

It is clear that the stamp for the short is the same as a voltage source with zero volts.



FIGURE B.6 Short circuit connected between two nodes.

TABLE B.9 Matrix stamp for short circuit.

| Row/column     | $V_k$ | $V_l$ | I  | RHS |
|----------------|-------|-------|----|-----|
| $\overline{k}$ |       |       | 1  | 0   |
| l              |       |       | -1 | 0   |
| Aux            | 1     | -1    | 0  | 0   |



FIGURE B.7 Equivalent circuit for coupled inductances.

# **B.1.7** Coupled Inductances

For most PEEC circuits, inductors are of fundamental importance. Of equal importance is the inclusion of mutual inductances as is evident from Chapter 5. We consider two cases. One is conventional inductances. The second case, with the same type of stamp, includes unconventional mutual inductances that include delays such that (FW)PEEC models can be represented.

The SPICE statements for mutual inductances, unfortunately, involve a coupling factor as an inheritance from the transformer equations for two inductors shown in Fig. B.7. An example for the SPICE representation is given by:

```
Lp11 Node1Name Node2Name 0.001uH
Lp22 Node3Name Node4Name 0.001uH
KL12 Lp11 Lp22 0.76
```

where *K* represents the coupling factor, which is given by  $K = Lp12/\sqrt{(Lp1\ Lp2)}$ . The computation of the coupling factor is a costly operation for millions of inductances. This computation is unnecessary, especially for potentially very large inductance matrices.

A more appropriate statement for mutual inductance can be used for the mutual inductance input descriptions. Due to the symmetry  $Lp_{12} = Lp_{21}$ , a better statement for the mutual coupling is

| Row/column     | $V_k$ | $V_l$ | $V_m$ | $V_n$ | $I_1$       | $I_2$            | RHS |
|----------------|-------|-------|-------|-------|-------------|------------------|-----|
| $\overline{k}$ |       |       |       |       | 1           |                  |     |
| l              |       |       |       |       | -1          |                  |     |
| m              |       |       |       |       |             | 1                |     |
| n              |       |       |       |       |             | -1               |     |
| Aux            | 1     | -1    |       |       | $-s L_{11}$ | $-s L_{12}$      |     |
| Aux            |       |       | 1     | -1    | $-s L_{21}$ | $-s L_{22}^{12}$ |     |
|                |       |       |       |       |             |                  |     |

TABLE B.10 Matrix element stamps for inductances and mutual inductances.

We also included a time delay example in this statement. This would be the delay for mutual inductances. The stamp for this case is given in Table B.10. The structure of the stamp is the same for the time domain.

For the time domain, we replace *s* with the appropriate numerical integration method in the auxiliary equations.

#### **B.1.8** Ideal Transformer Model

The ideal transformer is an important element in circuit theory that finds use for circuit synthesis and other applications. Importantly, this circuit element does not contribute to the states of the MNA descriptor system and it is also lossless. We can write the conventional circuit equations in terms of the ratio of the primary to secondary voltage ratio  $\beta$  with the current ratio of  $1/\beta$  such that power is conserved (Fig. B.8).

The stamp for the ideal two winding transformer is given in Table B.11.

The ideal transformer stamp for multiple windings is a straightforward extension of the two winding model given here.



**FIGURE B.8** Equivalent circuit for ideal transformer with two windings.

TABLE B.11 Matrix element stamps for two winding ideal transformer.

| Row/column     | $V_{k}$  | $V_l$ | $V_{\scriptscriptstyle m}$ | $V_n$ | $I_1$ | $I_2$    | RHS |
|----------------|----------|-------|----------------------------|-------|-------|----------|-----|
| $\overline{k}$ |          |       |                            |       | 1     |          | 0   |
| l              |          |       |                            |       | -1    |          | 0   |
| m              |          |       |                            |       |       | 1        | 0   |
| n              |          |       |                            |       |       | -1       | 0   |
| Aux            | 0        | 0     | 0                          | 0     | 1     | $-\beta$ | 0   |
| Aux            | $-\beta$ | β     | 1                          | -1    | 0     | 0        | 0   |

#### **B.2** CONTROLLED SOURCE STAMPS

Controlled sources are required for a large class of circuit solutions. For PEEC models, current controlled current sources (CCCSs) are used as well as voltage controlled voltage sources (VCVSs). We consider the four combinations between current and voltage sources in the following section.

#### **B.2.1** Current Controlled Voltage Source (CCVS)

The first controlled source stamp we consider is the current controlled voltage source (CCVS). The equation for the voltage is  $V_m - V_n = hName\ I_k$ , where *Name* represents the individual name assigned to the h factor (Fig. B.9).

As can be observed, the stamp is given for the case where the current is measured between nodes k and l is for the case of a short current measuring connection. The stamp can be simplified if we use a branch current as the measuring element. This part is clearly borrowed from the current measuring in the short stamp in Table B.12.

## **B.2.2** Voltage Controlled Voltage Source (VCVS)

Next, we consider the matrix stamp for a VCVS. The auxiliary equation for this case is  $V_m - V_n = kName (V_k - V_l)$ . This leads to the matrix stamp of Table B.13 (Fig. B.10).

### **B.2.3** Current Controlled Current Source (CCCS)

Next, we consider the matrix stamp for a CCCS (Table B.14). The current  $I_{mn} = fxxx I_{kl}$ . Here,  $I_{mn}$  is the current of the source from node m to node n (Fig. B.11).



**FIGURE B.9** Equivalent circuit for current controlled voltage source.

TABLE B.12 Matrix stamp for current controlled voltage source.

| Row/column | $V_{k}$ | $V_l$ | $V_m$ | $V_n$ | $I_{kl}$ | $I_{mn}$ | RHS |
|------------|---------|-------|-------|-------|----------|----------|-----|
| k          |         |       |       |       | 1        |          | 0   |
| l          |         |       |       |       | -1       |          | 0   |
| m          |         |       |       |       |          | 1        | 0   |
| n          |         |       |       |       |          | -1       | 0   |
| Aux        | 1       | -1    |       |       |          |          | 0   |
| Aux        |         |       | 1     | -1    | hxxx     |          | 0   |





FIGURE B.10 Equivalent circuit for voltage controlled voltage source.

TABLE B.13 Matrix stamp for voltage controlled voltage source.

| Row/column | $V_k$  | $V_l$ | $V_{m}$ | $V_n$ | $I_{mn}$ | RHS |
|------------|--------|-------|---------|-------|----------|-----|
| k          |        |       |         |       |          |     |
| ł          |        |       |         |       |          |     |
| m          |        |       |         |       | 1        |     |
| n          |        |       |         |       | -1       |     |
| Aux        | -kName | kName | 1       | -1    |          |     |

TABLE B.14 Matrix stamp for current controlled current source.

| Row/column     | $V_k$ | $V_l$ | $V_m$ | $V_n$ | $I_{kl}$        | RHS |
|----------------|-------|-------|-------|-------|-----------------|-----|
| $\overline{k}$ |       |       |       |       | 1               |     |
| $\ell$         |       |       |       |       | -1              |     |
| m              |       |       |       |       | fName<br>–fName |     |
| n              |       |       |       |       | -fName          |     |
| Aux            | 1     | -1    |       |       |                 |     |



FIGURE B.11 Equivalent circuit for current controlled current source.

FIGURE B.12 Equivalent circuit for voltage controlled current sources.

TABLE B.15 Matrix stamp for VCCS.

| Row/column | $V_k$  | $V_l$  | $V_{\scriptscriptstyle m}$ | $V_n$ | RHS |
|------------|--------|--------|----------------------------|-------|-----|
| ${k}$      |        |        |                            |       |     |
| l          |        |        |                            |       |     |
| m          | gName  | -gName |                            |       |     |
| n          | -gName | gName  |                            |       |     |

# **B.2.4** Voltage Controlled Current Source (VCCS)

The matrix stamp for a voltage controlled current source (VCCS) is used to represent some devices (Fig. B.12, Table B.15). The voltage controlled current is given by  $V_{kl} = gxxx (V_k - V_{\ell})$ . These stamps, together with Chapter 2, should yield a good understanding on how to form the appropriate circuit equations.

#### REFERENCES

- 1. C. Ho, A. Ruehli, and P. Brennan. The modified nodal approach to network analysis. *IEEE Transactions on Circuits and Systems*, 22(6):504–509, June 1975.
- J. Vlach and K. Singhal. Computer Methods for Circuit Simulation. Van Nostrand Reinhold Company, New York, 1983.
- 3. A. Ruehli Ed. *Circuit Analysis, Simulation and Design, Part 1*. Elsevier Science Publishers B.V., North-Holland, 1986.
- L. Pillegi, R. Rohrer, and C. Visweswariah. Electronic Circuits and System Simulation Methods. McGraw-Hill Book Company, New York, 1995.
- 5. F. N. Najm. Circuit Simulation. John Wiley and Sons, Inc., New York, 2010.
- L. W. Nagel. SPICE: a computer program to simulate semiconductor circuits. Electronics Research Laboratory Report, ERL M520, University of California, Berkeley, CA, May 1975.